<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>8-封装-简易axios函数-获取省份列表</title>
</head>
<body>
    <h2>封装-简易axios函数-获取省份列表</h2>
    <div class="box"></div>
    <script>
        /*
            封装-简易axios-获取省份列表
        */
        // 1. 定义myAxios 函数
        function myAxios(config) {
            console.log(config)
            // 2. 返回 promise 对象
            return new Promise((resolve, reject) => {
                // 3. 通过 XHR 发请求
                const xhr = new XMLHttpRequest()
                // 不传递方法 使用 GET
                xhr.open(config.method || 'get', config.url)
                xhr.addEventListener('loadend', () => {
                    if(xhr.status >=200 && xhr.status < 300) {
                        // 绝大多数 接口 返回的数据格式为 JSON
                        resolve(JSON.parse(xhr.response))
                    } else {
                        reject(new Error(xhr.response))
                    }
                }) 
                xhr.send()
            })
        }

        // 4. 调用函数实现功能
        myAxios({
            // 正确的URL
            url:'https://hmajax.itheima.net/api/province',
            // 错误的URL 测试用
            // url:'https://hmajax.itheima.net/api/province123',

            method:'get' // 省略默认为get
        }).then(res => {
            console.log(res)
            document.querySelector('.box').innerHTML = res.list
        }).catch(err => {
            console.log(err)
            console.dir(err)
            document.querySelector('.box').innerHTML = err.message
        })
    </script>
</body>
</html>